load("@io_bazel_rules_go//go:def.bzl", "go_library")
load("//bazel/go:go_test.bzl", "go_test")

go_library(
    name = "vtpm",
    srcs = [
        "attestation.go",
        "vtpm.go",
    ],
    importpath = "github.com/edgelesssys/constellation/v2/internal/attestation/vtpm",
    visibility = ["//:__subpackages__"],
    deps = [
        "//internal/attestation",
        "//internal/attestation/measurements",
        "@com_github_google_go_sev_guest//proto/sevsnp",
        "@com_github_google_go_tpm//legacy/tpm2",
        "@com_github_google_go_tpm_tools//client",
        "@com_github_google_go_tpm_tools//proto/attest",
        "@com_github_google_go_tpm_tools//proto/tpm",
        "@com_github_google_go_tpm_tools//server",
    ],
)

go_test(
    name = "vtpm_test",
    srcs = [
        "attestation_test.go",
        "vtpm_test.go",
    ],
    embed = [":vtpm"],
    # keep
    gotags = select({
        "//bazel/settings:tpm_simulator_enabled": [],
        "//conditions:default": ["disable_tpm_simulator"],
    }),
    deps = [
        "//internal/attestation/initialize",
        "//internal/attestation/measurements",
        "//internal/attestation/simulator",
        "//internal/logger",
        "@com_github_google_go_tpm//legacy/tpm2",
        "@com_github_google_go_tpm_tools//client",
        "@com_github_google_go_tpm_tools//proto/attest",
        "@com_github_google_go_tpm_tools//proto/tpm",
        "@com_github_stretchr_testify//assert",
        "@com_github_stretchr_testify//require",
        "@org_uber_go_goleak//:goleak",
    ],
)
